home *** CD-ROM | disk | FTP | other *** search
/ Light ROM 1 / LIGHT-ROM 1 (Amiga Library Services)(1994).iso / ffdisks / d969.lha / ACE / ACE-2.0.lha / DOCS.LHA / history < prev    next >
Text File  |  1994-01-19  |  39KB  |  943 lines

  1.  
  2.                 -----------
  3.                 ACE history        
  4.                 -----------        
  5.  
  6. 2/3/92            - Version 1.0 released to testers.
  7.  
  8. 13/3/92         - Numerous bug fixes:
  9.                 - parameters were being corrupted in some
  10.                   complex recursive calls (see ackermann.b).
  11.                 - array referencing with float index in INPUT
  12.                   was corrupting the input value.
  13.                 - narrator library was being expunged after
  14.                   every SAY command -- now only expunged
  15.                   once at the end of the program.
  16.  
  17. 14/3/92            - Above fixes released to testers.
  18.  
  19. 22/3/92 - 27/3/92    - Added block comments {...}.
  20.             - Added forward SUB declarations.
  21.             - Made ALL shared variables call-by-reference.
  22.             - Local SUB string duplication bug fixed (same
  23.               BSS object name being given to numerous
  24.               strings in different subprograms). 
  25.             - Re-released to testers.
  26.  
  27. 4/4/92            - Fixed relational string operators >,<,>=,<=
  28.               so that proper lexicographical comparisons are
  29.               made. Even though = and <> worked fine before,
  30.               these have also been modified. All now use a
  31.               more efficient C-style _strcmp function. 
  32.  
  33. 5/4/92            - Update sent to testers.
  34.  
  35. 7/4/92            - Maximum duration for SOUND (in db.lib) changed
  36.               to 999 from 77 to accomodate large sound samples
  37.               (see play.b for an example).
  38.  
  39. 21/4/92            - Sequential files simplified: EOF no longer looks
  40.               for EOF character (ASCII 28), it just tries to
  41.               seek past the current position returning a seek
  42.               error if it can't (ie: EOF reached).
  43.             
  44. 22/4/92            - Made CLS 1.3 and 2.04 compatible (in db.lib).
  45.             - Added logical shift functions [SHL(n,m),SHR(n,m)].
  46.             - Added turtle graphics XCOR and YCOR functions.
  47.             - Fixed long integer SUB bug: when calling a long
  48.               SUB with bsr, A68K spat the dummy when it saw
  49.               a '&' (eg: bsr TEST&). All '&'s replaced by '@'s.
  50.             - Added Ctrl-C trapping to compiler. Partly works.
  51.             - Fixed HEADING so it's always non-negative.
  52.  
  53. 2/5/92 - 8/5/92        - Added screens, PALETTE, PAINT, SYSTEM, DATE$.
  54.             - Made CIRCLE rendering faster by using DrawEllipse()
  55.               if full 360 degree ellipse is requested.
  56.             - Updated ace.doc and noted that SADD is not required
  57.               for string constants (ie: it's optional).  
  58.  
  59. 12/5/92            - Incorporated command line arguments [argcount,arg$].
  60.  
  61. 16/5/92            - Added single precision MOD.
  62.             - Fixed OCT$ which was giving incorrect results
  63.               for high values. Now only handles positive LONGs.
  64.             - Added BIN$. Like OCT$, n=abs(n) [n is LONG].
  65.             - Added FRE(n), with extras (see ace.doc).
  66.             - Added POTX(n) and POTY(n), where n=0 or 1.
  67.  
  68. 17/5/92            - Fixed bug in _deletewindow (db.s): Contents of
  69.               location zero was being moved into window lists
  70.               instead of #0 (!).
  71.  
  72. 6/6/92            - Fixed RIGHT$ bug: was returning the NULL string
  73.               when requested sub-string length equalled string 
  74.               length.
  75.             - Modified MOUSE(1) and MOUSE(2) code to work when
  76.               an ACE screen is active.
  77.  
  78. 8/6/92            - Added WorkBench startup capability.
  79.             - Added REPEAT...UNTIL loop construct ala Pascal
  80.             - Added CASE...END CASE construct.
  81.             - Added DAY function.
  82.  
  83. 9/6/92            - Added two compiler options:
  84.             
  85.                 (i) Ctrl-C break trapping.
  86.                    (ii) Optimisation (peephole).
  87.  
  88. 11/6/92            - Added definable numeric constants.
  89.             - Incorporated a BORDERLESS window for each
  90.               user-defined screen to facilitate IDCMP
  91.               events. 
  92.             - INKEY$ can now be used to read keystrokes
  93.               from a user-defined screen's window.
  94.             - Fixed RAW: window routine bug. The same
  95.               Wdw-id was unwittingly being allowed to be 
  96.               used for more than one window creation.
  97.             
  98. 12/6/92            - Modified CLS to work with user-defined screens.
  99.  
  100. 13/6/92 - 14/6/92    - Incorporated external variables
  101.               and functions (C, assembler...).
  102.  
  103. 28/6/92            - Modified LOCATE to work with user-defined screens.
  104.             - Fixed exponentiation so that it always returns
  105.               a float, in case of a negative exponent.
  106.             
  107. 29/6/92            - Incorporated full 32-bit math. ACE is now Wb 2.0
  108.               *reliant* (due to use of utility.library):
  109.  
  110.                 (i) 32-bit division replaced 32-bit \ 16-bit.
  111.                    (ii) 32-bit MOD replaced 32-bit MOD 16-bit.
  112.                   (iii) Multiplication:
  113.                     
  114.                         - 16 x 16 bit integer (new).
  115.                         - 32 x 32 bit integer (new).
  116.                         - float x float.
  117.  
  118.                    (iv) Array index calculations now use 32-bit
  119.                     unsigned multiplication. This fixes the
  120.                     bug that disallowed absolute indexes of
  121.                     greater than 65535.
  122.  
  123.             - Fixed yet another bug in INPUT: string array input
  124.               was producing pointers which all lead to one string.
  125.             - Defined numeric constants can now be signed.
  126.  
  127. 30/6/92            - Added LOF(n) function.
  128.             - Modified WAVE statement so that size of waveform
  129.               table can be up to 131070 bytes (hardware limitation).
  130.             - Fixed CHR$ bug: LONG parameters weren't being 
  131.               coerced to SHORT.
  132.  
  133. 2/7/92            - Added the CSTR function.
  134.  
  135. 3/7/92            - Added the HANDLE(n) function.
  136.             - split db.s into db.s and turtle.s due to
  137.               link problems: Blink or ACE programs GURU when 
  138.               db.lib too big. 
  139.  
  140. 4/7/92            - Added optional variable declarations.
  141.             - Wrote a simple pre-processor for ACE: app,
  142.               to allow include files.
  143.  
  144. 7/7/92            - Added event trapping: BREAK,MOUSE,TIMER(n).
  145.             - MENU event trapping not yet complete since
  146.               menus themselves have to be implemented.
  147.             - Added CSRLIN and POS for screens only so far.
  148.             - Changed over from SetSignal() to CheckSignal()
  149.               for ctrl-c -b compiler option and BREAK event
  150.               trapping.
  151.  
  152. 16/7/92            - Added: 
  153.                  (i) ADDRESS option for DIM.
  154.                 (ii) SIZE option for STRING.
  155.                    (iii) increment and decrement operators.
  156.                 (iv) indirection operators: @,*%,*&,*!.
  157.  
  158. 17/7/92    - 19/7/92    - Improved efficiency of strings and string arrays. 
  159.               The modifications also allow strings and string 
  160.               arrays to be passed by reference. 
  161.               
  162. 20/7/92            - Modified LOCATE, POS and CSRLIN so they take 
  163.               account of the current font (in ScreenMode).
  164.             - Improved PRINTS so that it behaves in almost the 
  165.               same way as PRINT.
  166.     
  167. 28/7/92            - Added SIZEOF function.
  168.             - Fixed a long-standing bug that caused GURUs
  169.               during parameter passing when a context-switch
  170.               occurred, corrupting the stack. This is a short-term
  171.               fix only, and will be replaced by use of C-style
  172.               parameter passing.
  173.  
  174. 8/8/92 - 9/8/92     - Added structures.
  175.             - Modified VARPTR to handle structures.
  176.             
  177. 6/12/92            - Divided main linked library into functional modules
  178.               which are joined to produce db.lib. The code from
  179.               db2.lib and turtle.lib has been incorporated into
  180.               db.lib.
  181.  
  182. 6/12/92 - 7/12/92    - Further modularised compiler source files. I could
  183.               *really* use a make utility now!
  184.  
  185. 8/12/92            - Changed SHR and SHL code generation from lsr.l and
  186.               lsl.l to asr.l and asl.l respectively, in order to
  187.               handle shifts of negative numbers correctly! (oops)
  188.  
  189. 12/12/92 - 13/12/92    - Improved PAINT. Too much RAM was being reserved.
  190.  
  191. 12/12/92 - 13/12/92    - Added AREA, AREAFILL, PATTERN.
  192.  
  193. 13/12/92        - Added SCROLL, SPACE$.
  194.             - Fixed bug in PAINT: border color not being reset.
  195.  
  196. 21/12/92        - Improved LOF by using Seek() rather than
  197.               Examine() to find file length. This removed
  198.               the need to use the 2.04 function DupLockFromFH()
  199.               making LOF 1.3 compatible.
  200.             - Reverted to SetSignal() from CheckSignal() to
  201.               preserve 1.3 compatibility.
  202.  
  203. 22/12/92        - Replaced 32-bit integer math routines in  
  204.               utility.library with lmath.a routines from 
  205.               Sozobon's ZC.lib. This obviates the need for the 
  206.               2.04 utility.library making all ACE integer math 
  207.               1.3 compatible. The lmath.a module has been
  208.               incorporated into db.lib, with slight modifications
  209.               (source is called lmath.s).
  210.             - Brought DIM in line with AmigaBASIC. If a dimension
  211.               is specified as N, the resulting subscript range
  212.               is 0..N, rather than 0..N-1 (as it is in C and was
  213.               in ACE up until now).
  214.             - Removed reference to ACElibs: from libfunc.c, so 
  215.               this no longer has to be ASSIGNed in the user-startup
  216.               or startup-sequence script.
  217.               
  218. 26/12/92        - Added support for Workbench arguments in the form of
  219.               an include file (WBarg.h).
  220.  
  221. 27/12/92        - Modified APP so that an include file is only ever
  222.               included once per program. APP now also handles
  223.               single and multi-line comments ("'" and {..}).
  224.  
  225. 28/12/92 - 29/12/92    - Fixed some long-standing little bugs in the lexical
  226.               analyser.
  227.             - Moved the code for comments from the parser to the 
  228.               lexical analyser.
  229.             - Added the rest of AmigaBASIC's reserved words for 
  230.               completeness and because I may get around to
  231.               implementing some things that I didn't originally
  232.               think I would.
  233.             - Changed the lexical analyser's reserved word search
  234.               method from sequential to binary. This has resulted 
  235.               in a dramatic improvement in compilation speed 
  236.               (around twice as fast as before). I should have done
  237.               this a long time ago.
  238.             - Added code to prevent APP from looking for comments
  239.               inside string literals!
  240.             - Removed ++ and -- operators from factor() because
  241.               they are confusing (IMHO). Pre-increment (++) and
  242.               pre-decrement (--) can now only be applied to 
  243.               variables, not as part of an expression.
  244.  
  245. 30/12/92        - Added STRING$ and INSTR.
  246.  
  247. 1/1/93            - Added descriptions for ALL functions and commands
  248.               in ref.doc since some people using ACE won't have
  249.               the AmigaBASIC manual.
  250.  
  251. 5/1/93 - 6/1/93        - Work on sequential files:
  252.     
  253.                 - CLOSE can be used to close more than
  254.                   one file now, but at least one filenumber
  255.                   still has to be specified.
  256.  
  257.                 - Added LINE INPUT #filenumber,string-variable.
  258.  
  259.                 - Added INPUT$(X,[#]filenumber) and ditched
  260.                   INP$.
  261.  
  262.                 - Improved performance of all sequential file 
  263.                   functions in db.lib.
  264.     
  265.                 - Made file format produced by WRITE identical
  266.                   to AmigaBASIC.
  267.  
  268.                 - Added PRINT #filenumber,expression-list.
  269.     
  270.                 - Added INPUT#filenumber,variable-list.
  271.  
  272.             - ACE files are now very nearly identical to AmigaBASIC.
  273.  
  274. 12/1/93            - Fixed a bug in VAL that was causing numbers with
  275.               more than 8 decimal places to give weird results.
  276.             - In considering the use of double-precision math
  277.               in ACE, I have realised that Motorola FFP values
  278.               can handle up to 8 decimal places of accuracy,
  279.               whereas in AmigaBASIC, a number with >= 7 decimal
  280.               places is classed as a double-precision value. 
  281.               Given the degradation in accuracy which occurs
  282.               when more than 8 digits (counting both sides of 
  283.               the decimal point) are specified in an ACE FFP 
  284.               value, AmigaBASIC's double-precision convention
  285.               will probably be followed in ACE.
  286.             - Increased the size of the buffer for INPUT$ from
  287.               MAXSTRINGSIZE to MAXSTRINGSIZE*32 (32K currently)
  288.               to facilitate the reading of longer files.
  289.             - Made all library functions which impose a limit
  290.               upon the number of characters in a string or buffer
  291.               use MAXSTRINGSIZE-1 (changed string.s and file.s).
  292.  
  293. 13/1/93            - Stopped a large memory leak when ACE quits due to
  294.               an internal list memory allocation error. There
  295.               still seems to be a small leak however.
  296.             - Modified the bas script so that intermediate 
  297.               files are deleted after each stage of the compile-
  298.               assemble-link process. This frees up more RAM. 
  299.               
  300. 19/1/93            - Fixed a bug in the lexical analyser which was
  301.               returning a value of 1 for ANY number of the
  302.               form nnE[+|-]mm when mm was 0.
  303.  
  304. 20/1/93            - AREA was only allowing 19 points, not 20. Fixed this.
  305.  
  306. 21/1/93            - Fixed a weird AREAFILL and PAINT bug. Both of 
  307.               these routines allocate and initialise a temporary
  308.               rastport for area/flood filling. Although the
  309.               memory was being freed, the TmpRas pointer was
  310.               not zero'd. On the next call to PRINTS or Text()
  311.               a GURU 8100 000C resulted (recoverable alert under
  312.               2.04). It appears that Text() or some lower-level
  313.               graphics primitive tries to use an existing TmpRas
  314.               if one seems to exist. After making Rp->TmpRas=NULL
  315.               the bug disappeared.
  316.  
  317. 26/1/93            - Modified APP so that lines taken up by block
  318.               comments are represented by line-feeds in the
  319.               destination file so as to prevent line mismatches
  320.               between the latter and the source file. This still
  321.               doesn't get around the problem of line mismatches
  322.               caused by #include directives though. 
  323.  
  324. 31/1/93            - Changed effect of DEFDBL and <ident># so that 
  325.               they yield single-precision data types rather
  326.               than double-precision. This avoids any problems
  327.               further down the line (because double-precision
  328.               is not yet supported).
  329.  
  330. 2/2/93            - Added ctrl-c user break trapping to APP and 
  331.               improved the reliability of ACE's ctrl-c trapping.
  332.  
  333. 4/2/93            - ACE v1.0 released to the public! First started
  334.               work on ACE in October 1991.
  335.  
  336. *******************************************************************************
  337.  
  338. 6/2/93            - Work on ACE v1.01 commenced.
  339.  
  340.             - Improved compile-time error handling. Now, the
  341.               whole offending line is displayed and a carat
  342.               marks the place in the line where the error was
  343.               identified. The rest of that line is then ignored
  344.               so as to prevent further spurious errors. More 
  345.               work remains to be done for this revision on this.
  346.             - The observation was made that AmigaBASIC does NOT
  347.               evaluate exponentiation operations from right to
  348.               left as previously thought, but from left to right
  349.               as with all other operations. This obviates the
  350.               need to change ACE's exponentiation evaluation 
  351.               method. 
  352.             - AmigaBASIC does not allow a term of the form:
  353.               n^-m or n^(-m). ACE allows the latter but not
  354.               the former.
  355.              
  356. 7/2/93            - Fixed INPUT from RAW: windows so that the 
  357.               destructive backspace key actually erases text
  358.               as it does in a CON: window. The routine was 
  359.               also cleaned up in general and made more
  360.               efficient.
  361.             - Sequential file OPEN modes can now be upper
  362.               or lower case (ie: "I" or "i" etc).
  363.         
  364. 11/2/93            - Fixed the FOR loop index bug by not allowing
  365.               a shared variable to be used as the index.
  366.             - Trailing characters (other than '&') can now 
  367.                be used to coerce one numeric literal to 
  368.               another. Note that & and % have the same
  369.               effect as CLNG and CINT in ACE (ie: they
  370.               _always_ round up). 
  371.  
  372. 12/2/93            - String literals now need not have an end quote.
  373.               Such a string will be truncated at the end of 
  374.               the line.
  375.             - Fixed bug in LINE INPUT# whereby the variable's
  376.               data type was not correctly established if the
  377.               variable was declared with STRING.
  378.             - LINE INPUT# was also modified to accept a string
  379.               array as well as a simple string variable.
  380.  
  381. 13/2/93            - BASIC line numbers have been implemented for 
  382.               backward compatibility with old BASIC programs 
  383.               and for consistency with AmigaBASIC.
  384.  
  385. 14/2/93            - Fixed a bug in STRUCT..END STRUCT & CASE..END CASE
  386.               where blank lines caused spurious compilation errors.
  387.             - Changed a hard-coded X:Y screen ratio constant in the
  388.               turtle graphics section of db.lib to a data item 
  389.               which can be accessed/modified with ACE's EXTERNAL
  390.               directive (EXTERNAL _tg_xy_ratio).
  391.             - Made several compile-time errors "cleaner".
  392.  
  393. 15/2/93            - Improved error handling for undeclared arrays.
  394.             - Fixed a bug in INPUT#. It was crashing when the
  395.               file wasn't open or the file number was invalid.
  396.             - Rewrote VAL code in C. It now handles fixed-point
  397.               and exponential format single-precision values
  398.                 as well as decimal, octal and hexadecimal integers.
  399.               
  400. 16/2/93            - Rewrote _short_from_string and _long_from_string
  401.               in C. These routines are used by INPUT and INPUT#
  402.               to extract integer values from strings. Decimal,
  403.               octal and hexadecimal values may now be handled 
  404.               via INPUT and INPUT#.
  405.  
  406. 18/2/93            - Rewrote _strsingle which is used by PRINT#, WRITE#,
  407.               PRINTS and STR$ so that it produces fixed-point 
  408.               and exponential format single-precision output.
  409.               PRINT also uses this routine now. The new version
  410.               of _strsingle (written in C) is somewhat faster than 
  411.               the original which was badly coded in assembler.
  412.               A single-precision number is converted to the form:
  413.               -|+.mmmmmmmmE-|+nn by fpa(). If 7 <= nn < -6 the
  414.               number is displayed in exponential format.      
  415.             - Added a FIX command (see ref.doc for details) which
  416.               alters the number of decimal places a FFP value is
  417.               rounded to.
  418.  
  419. 19/2/93            - Replaced _round routine in db.lib. This is used by    
  420.               by CINT and CLNG and wherever a float needs to be
  421.               rounded to an integer. The new version seems to be
  422.               faster than the old one which used fpa() and arnd().
  423.               The former only uses mathffp.library functions.
  424.  
  425. 20/2/93            - ACE v1.01 released.
  426.  
  427. *******************************************************************************
  428.  
  429. 28/2/93            - Work on ACE v1.02 commenced.
  430.  
  431.             - Added a compiler switch (-i) which makes an icon 
  432.               for the executable just created by ACE.
  433.             - Added ON <event-specifier> GOTO. This is in addition
  434.               to ON <event-specifier> GOSUB which was already
  435.               implemented.
  436.             - Changed all bsr and bra 68000 instructions to jsr
  437.               and jmp respectively in order to avoid the 32K
  438.               displacement limit. Moreover, some beq instructions 
  439.               have been replaced by a combination of bne and jmp 
  440.               to avoid this limit. This included changes to the
  441.               code for: IF, CASE, REPEAT..UNTIL, WHILE..WEND.  
  442.             - Fixed a bug whereby return code in d0 was being 
  443.               overwritten before the program ended, due to calls
  444.               to cleanup routines.     
  445.  
  446. 1/3/93            - Changed all occurrences of bsr in db.lib and 
  447.               startup.lib sources to jsr so as to avoid the 
  448.               32K limit mentioned above (28/2/93).
  449.             - Implemented KILL and NAME.
  450.             - ON..GOTO and ON..GOSUB implemented.
  451.  
  452. 6/3/93 - 10/3/93    - Rewrote SAY command in C and added support
  453.               for mode-array(7) and mode-array(8) such that
  454.               ACE SAY now allows for asynchronous speech.
  455.             - Moreover, a SAY(n) function has been added,
  456.               where SAY(0) returns -1 or 0 to indicate whether
  457.               there is active asynchronous speech, SAY(1) returns 
  458.               the mouth width and SAY(2) returns the mouth height 
  459.               corresponding to the phoneme being spoken. 
  460.  
  461. 14/3/93            - Added support for SAY mode-array element #6. This
  462.               allows for 12 different audio channel allocation
  463.               combinations as per AmigaBASIC. See ref.doc for more.
  464.             - Improved performance of INSTR function by only 
  465.               checking first character of target string against
  466.               each character in the source string until they
  467.               match. At this point a full sub-string comparison
  468.               is carried out.
  469.  
  470. 12/4/93            - Fixed a bug in shared library function declaration
  471.               code in which a search for a non-existent function
  472.               sometimes caused the compiler to hang. The routine
  473.               responsible was rewritten with a resultant speedup.
  474.  
  475. 13/4/93            - Fixed a bug which had been lurking for some time,
  476.               related to string variable assignments. A string
  477.               variable not declared with the STRING command was
  478.               not always being associated with a storage area.
  479.               In fact, only the first occurrence of the string
  480.               was being so associated. If this first occurrence
  481.               was in a CASE or IF statement, it might never be
  482.               reached with the consequence that the string
  483.               in question was associated with a random address
  484.               in memory! This is now fixed, so that each time
  485.               the string is assigned a value, it is bound to
  486.               its correct address. Obvious in hindsight.
  487.  
  488. 15/4/93            - Commodore Australia have given me permission to 
  489.               include the .bmap files in the ACE archive. I 
  490.               don't have this in writing yet though. ConvertFD 
  491.               can not be distributed however, so a completely
  492.               new (functionally equivalent) program will have
  493.               to be written. 
  494.  
  495. 16/4/93    - 17/4/93    - A couple of bugs which were related to the above
  496.               string bug (13/4/93) were fixed because they
  497.               were missed at the time and resulted in complaints
  498.               from A68K (legitimate ones) about unknown symbols.
  499.             - Testing has shown that a plethora of problems
  500.               of previously unknown origin were related to the
  501.               string bugs described above. Also, Michael 
  502.               Zielinski has reported that there are no longer 
  503.               any Enforcer hits from ACE now after the fixes
  504.               from 13/4/93.
  505.  
  506. 18/4/93            - ACE v1.02 released.
  507.  
  508. *******************************************************************************
  509.  
  510. 9/5/93            - Work on ACE recommenced.
  511.  
  512.             - ARG$(0) added for access to a CLI command's name.
  513.  
  514. 11/5/93            - CHDIR command implemented.
  515.  
  516. 18/5/93 - 21/5/93    - Enhanced FILES command implemented. 
  517.  
  518. 30/5/93            - A few string functions (ARG$,SPACE$,STRING$,UCASE$)
  519.               were using a single buffer for each result
  520.               which was being overwritten during evaluation
  521.               of an expression such as: UCASE$(..) = UCASE$(..)
  522.               This was fixed by creating a temporary string
  523.               for each function call as with other string 
  524.               functions. 
  525.             - * INPUT$ still uses a single 32K buffer however! *
  526.  
  527. 6/6/93            - Command line argument handling routines completely
  528.               rewritten in C. This fixed an infrequent bug in 
  529.               which the last argument wasn't always being parsed
  530.               and enabled the correct parsing of quoted arguments.
  531.             - Added two new compiler switches: -E and -c. The
  532.               first creates a file called ace.err which contains
  533.               all the compile-time errors at the end of an ACE run.
  534.               The second includes each ACE source code line as a
  535.               comment in the assembly source code.
  536.  
  537. 7/6/93            - A bug in exec.library version checking was
  538.               preventing CLS from correctly changing the 
  539.               background colour after a COLOR command on 
  540.               machines higher than V37 (ie: Wb 3.0 machines 
  541.               like the A1200). This is now fixed.
  542.  
  543. 10/6/93            - Fixed a bug in which CLOSE was sometimes causing a
  544.               privilege violation processor trap. DOSBase wasn't
  545.               always being moved to a6 prior to calling the 
  546.               dos.library Close function (!). 
  547.  
  548. 12/6/93            - Added ptr_term() function between expterm() and
  549.               factor() in expression parser to correct the
  550.               precedence of !%, !& and !* operators.
  551.             - I have decided to leave SUB parameters as they
  552.               are for now. See ace.doc Subprograms section
  553.               for latest details.
  554.             - Added SLEEP command. So far only works when in
  555.               screen mode.
  556.  
  557. 13/6/93            - Fixed a bug in which insymbol() was being called
  558.               one too many times by the "@" code when the address
  559.               of a structure member was being found.
  560.             - Added code to address_of_object() (used by @ and
  561.               VARPTR) to find the address of an array element.
  562.               This code - and therefore @ and VARPTR - can now 
  563.               find the address of:
  564.             
  565.                     - simple variables
  566.                     - external variables
  567.                     - arrays
  568.                     - array elements
  569.                     - structures
  570.                     - structure members
  571.         
  572.             - Added a -l compiler switch which displays each
  573.               ACE program source line before it is compiled. 
  574.             - Implemented SWAP command ala AmigaBASIC. It swaps
  575.               simple and external variables, array elements,
  576.               structures or structure members.
  577.  
  578. 14/6/93            - Modified the handling of string value parameters
  579.               so that association with BSS storage occurs at the
  580.               start of subprogram execution rather than waiting
  581.               for an assignment. This fixes the address for the
  582.               life of the parameter. One consequence of this is
  583.               that VARPTR and @ correctly access the address
  584.               of the formal parameter, not the actual parameter.
  585.               This also ensures the correct handling of such
  586.               parameters by the SWAP command.
  587.  
  588. 19/6/93            - Modified address_of_object() so that when the
  589.               address of a structure variable is requested
  590.               with @ or VARPTR, the address of the variable
  591.               in the stack frame is returned, rather than the
  592.               start address of the structure. The latter can
  593.               still be obtained by simply referencing the
  594.               variable (eg: x = mystructvar). The modification
  595.               makes variable structure parameters possible 
  596.               (see ace.doc "Structures" for an example).
  597.  
  598. 20/6/93            - Made structures sharable with the SHARED statement.
  599.             - SUB parameters may now be preceded by SHORTINT,
  600.               LONGINT,SINGLE or STRING to indicate data type
  601.               rather than always having to use %,&,! or $.
  602.             - String array elements can now have a specifiable
  603.               size via a new SIZE option in DIM. 
  604.             - String variable declarations with STRING command
  605.               will now accept defined constants for the SIZE
  606.               option.
  607.  
  608. 29/6/93            - A bug in both BIN$ and OCT$ (such that negative 
  609.               values were being negated) was fixed.
  610.  
  611. 30/6/93            - ADDRESS data type added. This is really just an 
  612.               alias for LONGINT but it makes a lot more sense
  613.               when viewed in the context of a variable, parameter
  614.               or structure member which holds an address.
  615.             - It is now possible to declare a SUB to be of a
  616.               certain data type by using: LONGINT,SHORTINT etc.
  617.             - Shared structures worked fine when modifying/using
  618.               structure members, but not when modifying the
  619.               address held by the structure variable itself. 
  620.               This has been fixed.
  621.  
  622. 1/7/93            - ALLOC function implemented. This is a hassle-free
  623.               Unix-style memory allocator which makes use of
  624.               the Alloc/FreeRemember functions of Intuition.
  625.  
  626. 2/7/93            - Added ASSEM..END ASSEM for inline assembly code
  627.               inclusion.
  628.             - OPTION <switch>+|-[,<switch>+|-..] can now be 
  629.               used to set compiler directives as well as being
  630.               able to do so from the command line.
  631.  
  632. 3/7/93            - Fixed a bug in which the type of structure
  633.               members was not being correctly determined by
  634.               the SWAP command such that short integer and
  635.               string structure members were not being handled
  636.               properly.
  637.  
  638. 4/7/93            - SIZEOF now correctly returns the size of a
  639.               structure variable. Prior to today, only
  640.               the size of a structure definition was 
  641.               correctly returned. This was an oversight.
  642.  
  643. 10/7/93            - ACE version 1.1a released.
  644.  
  645. *******************************************************************************
  646.  
  647. 4/9/93            - Work on ACE v2.0 commenced.
  648.  
  649. 4/9/93 - 12/9/93    - Flexible serial I/O support added to ACE. Up to
  650.               255 channels are supported.
  651.             - ERR function added (serial errors only so far).
  652.  
  653. 25/9/93            - Serial I/O routines tidied up. 
  654.             - ERROR trapping implemented (serial errors only 
  655.               so far).
  656.  
  657. 26/9/93            - Buffered file I/O error codes added. These are
  658.               returned by ERR and recognised by ON ERROR.
  659.  
  660. 10/10/93        - TAB function now works for screens.
  661.             - Implemented PTAB function.
  662.             - Made PRINT command screen/window mode transparent.
  663.             - This is all part of a conspiracy to make ACE able
  664.               to handle Intuition and DOS windows completely
  665.               transparently. Next comes INPUT transparency. 
  666.               
  667. 11/10/93        - Made INPUT command screen/window mode transparent!
  668.             - Implemented SPC function.
  669.  
  670. 24/10/93        - Extended ctrl-c break trapping to screen mode.
  671.  
  672. 24/10/93 - 25/10/93    - Intuition windows implemented! ACE now allows
  673.               for windows on screens! In fact, all windows
  674.               except the shell/CLI are now Intuition windows
  675.               in ACE. Next comes menus and gadgets...
  676.             - Added WINDOW(12) and WINDOW(13) which return
  677.               font width and height (respectively) for the
  678.               current output window.
  679.             - Screen colours are now adopted from Workbench
  680.               as per AmigaBASIC.
  681.  
  682. 26/10/93        - Window close event trapping implemented. Since
  683.               ACE doesn't automatically handle the closing of
  684.               windows when the close gadget has been clicked,
  685.               a compiler switch (-w) and user-defined event
  686.               trapping was deemed to be the best way to handle 
  687.               this.
  688.             - Fixed yet another bug in CLS which was causing
  689.               the print position to be incorrectly aligned in
  690.               Intuition windows.
  691.  
  692. 1/11/93            - ACE windows now handle certain control characters
  693.               (ASCII: 7,8,9,10,12,13) in exactly the same way as
  694.               AmigaBASIC, eg: CHR$(7) rings the BELL!
  695.             - Implemented boolean gadgets and gadget WAITing.
  696.               Next comes gadget event trapping, a gadget function,
  697.               string and proportional gadgets, as well as some
  698.               tidying up.
  699.  
  700. 2/11/93            - Implemented GADGET(n) function and ON GADGET event
  701.               trapping.
  702.  
  703. 6/11/93            - Implemented String and LongInt gadgets.
  704.  
  705. 7/11/93 - 8/11/93    - Implemented proportional gadgets (horizontal and
  706.               vertical sliders). 
  707.             - Window close gadget events are now passed on for
  708.               ON WINDOW or -w compiler switch trap handling.
  709.  
  710. 9/11/93 - 10/11/93    - Menus have finally been implemented in ACE!! This
  711.               includes menu command keys (keyboard shortcuts),
  712.               MENU WAIT command, MENU event trapping and MENU(n)
  713.               function.
  714.  
  715. 5/12/93            - MENU and GADGET trapping/WAITing now fully 
  716.               supports WINDOW close-gadget handling.
  717.             - WAIT GADGET 0 implemented: waits for ANY gadget.
  718.               This is in my opinion, the best method of dealing
  719.               with gadgets in ACE since it is very flexible and
  720.               CPU-nice. It is however modal.
  721.             - Fixed two bugs in the completely rewritten INPUT
  722.               code: no space after "?" and no scrolling after
  723.               INPUT at bottom of window. 
  724.  
  725. 15/12/93        - Fixed PRINT/PRINTS/PRINT# inability to accept 
  726.               some parameters delimited only by spaces. ACE 
  727.               seems to accept just about anything delimited
  728.               by spaces now (or of course by commas/semicolons).
  729.             - Fixed a long-standing bug in which the compiler
  730.               would incorrectly parse IF .. THEN PRINT ELSE ..
  731.               such that ELSE was ignored. This works fine now.
  732.  
  733. 16/12/93 - 17/12/93    - Fixed BSS structure object alignment so that
  734.               all such structures will be long-word aligned.
  735.             - Reduced the amount of code written to the target
  736.               file when internal compiler errors occur to a
  737.               short skeleton program. This may yet be further
  738.               minimised.
  739.             - I have started the process of improving the
  740.               efficiency of the compiler's memory management
  741.               routines by using code similar to the ALLOC
  742.               function in ACE as well as trying to reduce
  743.               the size of each node in the symbol table. 
  744.             - The arbitrary DIM limit of 10 dimensions has
  745.               been removed; 255 are now allowed as per 
  746.               AmigaBASIC.
  747.  
  748. 17/12/93 - 18/12/93    - Memory management and efficiency improvement 
  749.               continues.
  750.             - The compilation line number indicator has been
  751.               streamlined to cut down on I/O and improve its
  752.               appearance.
  753.             - Memory leaks now seem to be "capped".
  754.             - The arbitrary SHARED limit of 40 has been lifted.
  755.             - Fixed a problem caused by editors which don't
  756.               automatically append a line-feed (ASCII 10)
  757.               to the end of a file, such that the last line
  758.               of a program wasn't being parsed.
  759.             - SERIAL OPEN randomly generating ERR=300 (OPEN_ERR).
  760.               Probably caused by OpenDevice() result not being
  761.               coerced from BYTE to ULONG (??). Fixed this.
  762.             - Fixed a bug in which insufficient memory was
  763.               being allocated to hold DIM index information. 
  764.  
  765. 24/12/93        - CHR$(13) now only performs a CR (in user-defined
  766.               windows) as per the CON: and RAW: windows.
  767.               In AmigaBASIC, CHR$(13) does the same as CHR$(10), 
  768.               ie: LF.
  769.             - Appended ASL library stub (generated by genstubs)
  770.               to ACE's ami.lib so that ASL file requesters can
  771.               be used by FILEBOX$ function (see below).
  772.             - Implemented MSGBOX and FILEBOX$ functions which
  773.               easily allow the ACE programmer to invoke system 
  774.               and file requesters respectively. Thus far only
  775.               the ASL file requester has been implemented. The
  776.               next step is to test for the operating system
  777.               version at run-time and call different file
  778.               requester code for Amigas running anything less
  779.               than 2.04.
  780.             - Started writing the code for an IDE so that ACE
  781.                can be run from the Workbench. This will be
  782.               developed over the coming months, but a simple
  783.               version should be working within days.
  784.  
  785. 25/12/93        - Yes I know it's Xmas. It's also 1 am. 
  786.               So I'm a fanatic! :-).
  787.             - I have *finally* found the ZC code which causes
  788.               the conflict with ACE's ctrl-c trapping mechanism.
  789.               Upon examination of the ZC source code, I found
  790.               the culprit to be a function called Chk_Abort().
  791.               This I redefined (in misc.c of ACE's source code)
  792.               to do nothing except return 0. This redefinition
  793.               has also been made in app.c.
  794.             - APP now uses the alloc()/free_alloc() functions
  795.               for handling memory allocations. 
  796.  
  797. 26/12/93        - Modified ACE so that the ".b" extension can be
  798.               used. This is still optional though. The main
  799.               reason for doing this was to accomodate TDS's
  800.               (Twilight Development System, an excellent
  801.               shareware IDE) apparent need to have the
  802.               extension of source files made explicit.
  803.             - Fixed MsgBox so that it works correctly under
  804.               Wb 1.3. The requester wasn't taking on the
  805.               correct proportions.
  806.             - Added support for a Wb 1.3 FILEBOX$. It requires
  807.               the arp.library. I may eventually replace this
  808.               with standalone code (when I get time to write 
  809.               a nice, simple file requester or some kind soul
  810.               gives me the source for one).
  811.  
  812. 27/12/93        - Implemented "SYSTEM command-string" which has the
  813.               same effect as Execute(command-string,0L,stdout).
  814.             - Finally got around to implementing DEF FN, as a 
  815.               simple variation on SUB.
  816.  
  817. 28/12/93        - Optional parameter is now legal in ACE's RND
  818.               function. It is currently only a dummy.
  819.             - FileBox$ modified so that a single string
  820.               parameter is required. This allows a title
  821.               for the requester to be supplied (eg: "Open"). 
  822.  
  823. 2/1/94            - As promised above (see 24/12/93) I've written
  824.               a simple IDE for ACE called AIDE. This is 1000
  825.               lines of ACE code and the results are fairly
  826.               pleasing. The source code for this program
  827.               will be included in the archive as an example
  828.               of what can be done with some of ACE's more
  829.               recent features. AIDE currently only runs
  830.               properly under Wb 2.04 (and up).  
  831.             - Fixed a bug in which IF..THEN struct->member...
  832.               was causing an Undeclared label error!
  833.             - Changed the return values of MsgBox to -1 and 0
  834.               instead of 1 and 0 so that "OK" (or whatever the
  835.               first gadget is) can be seen as a boolean TRUE.
  836.             - String structure members didn't allow a named 
  837.               numeric constant to be given for the optional 
  838.               SIZE parameter, but they do now.
  839.             - String array, structure member and variable 
  840.               declarations allowed a string of non-positive
  841.               size. This has been fixed.
  842.  
  843. 3/1/94            - I started out with the simple intention of
  844.               adding a bit more compatibility to ACE's
  845.               shared library function handling and ended
  846.               up with almost total compatibility with
  847.               AmigaBASIC. Only "almost" because shared
  848.               library function declarations are still
  849.               mandatory in ACE. That's now the only
  850.               difference. The previous ACE syntax is
  851.               still supported though.  
  852.              
  853. 4/1/94            - I have written an ACE program (autonum.b) 
  854.                 which takes the drudgery out of maintaining
  855.               the line number references to the sections
  856.               in ace.doc and also adds page numbers.
  857.         
  858. 5/1/94            - Implemented a SYSTEM function which returns
  859.               ExecBase->libNode.lib_Version (eg: 34 = Wb 1.3).
  860.  
  861. 6/1/94            - After some false starts, I've added "EXIT FOR"
  862.               which provides a (read: THE) clean way of exiting 
  863.               from a FOR..NEXT loop in ACE.
  864.             - Implemented INPUTBOX and INPUTBOX$! I took the
  865.               syntax from Visual Basic's functions of the same
  866.               names. ACE now has 3 standard requester types.
  867.  
  868. 7/1/94            - Completed the last bits of improving the
  869.               efficiency of ACE's memory allocation routines.
  870.               I couldn't get it to produce any memory leaks.
  871.  
  872. 8/1/94            - Well, I thought I was finished with the memory
  873.               allocation stuff from yesterday, but I decided
  874.               to try speeding things up some more. This I have
  875.               done by decreasing the number of allocation
  876.               function calls by half for the code list. I've
  877.               also switched to ZC.lib's malloc() & free() which
  878.               seem to be solid.
  879.             - Tested ACE on an A1200 this morning. It seems fine
  880.               although a "Magic Menus" commodity didn't get along 
  881.               too well with ACE's menus.
  882.             - Just finished my standard pre-release testing run 
  883.               of ACE which involves compiling and running over
  884.               50 programs under Wb 2.04. A number of programs
  885.               were also tested under Wb 1.3 with and without
  886.               fast RAM switched on.
  887.  
  888. 9/1/94            - Fixed a bug which made A68K generate syntax errors 
  889.               because some label names conflicted with assembly 
  890.               keywords (CPU register names to be specific).
  891.             - In the process I found a couple more bugs:         
  892.               variables starting with an underscore but with
  893.               no trailing type character were not being assigned
  894.               a data type; DEF FN return values were not always
  895.               being coerced correctly.
  896.             - Everything from yesterday is now being re-tested.
  897.  
  898. 10/1/94            - Fixed a bug in which ACE tried to clean up
  899.               asynchronous speech when the narrator.device
  900.               was not present and SAY had aborted. Sigh. 
  901.               Another testing run me-thinks.
  902.  
  903. 12/1/94 - 13/1/94    - Peter Zielinski (Sydney) has been testing ACE the 
  904.               last couple of days and found a problem in which 
  905.               menus looked weird with some fonts. This has been 
  906.               fixed.
  907.             - I realised that there would be a similar problem
  908.               with InputBox$ and fonts other than Topaz 8. This  
  909.               function has been modified to handle non-topaz-8
  910.               requester title fonts, but Topaz 8 is used for
  911.               the requester prompt and boolean gadget text.
  912.             - Fixed a bug in which LIBRARY CLOSE (used without  
  913.               a specific library name) was producing incorrect
  914.               library base names for libraries not on ACE's
  915.               standard libraries list (ie: those opened at
  916.               the start of a program run and closed at the end)
  917.               resulting in an undefined label error from A68K.
  918.             - Also, a library base (again, for non-ACE-listed
  919.               libraries) now gets zeroed after a call to ACE's   
  920.               _close_library routine in case it's closed again
  921.               (_close_library check for NULL).
  922.  
  923. 14/1/94            - Improved menu text rendering by using the graphics
  924.               library TextLength() function to get more precise
  925.               widths for menu titles and items.
  926.  
  927. 15/1/94            - Fixed a bug in which INPBOX[$] was growing in
  928.               size (from the bottom) when called multiple times
  929.               with a non-topaz font as the screen font.
  930.             - Tried many things to fix a bug in which INPUTBOX[$]
  931.               gadgetry display gets corrupted by _some_ fonts.
  932.             - Improved INPUTBOX[$] by making the string gadget
  933.               active when the requester is rendered. This means
  934.               that the user doesn't have to select the string
  935.               gadget before entering text into it. 
  936.             - Tweaked the width of menu item text highlighting.
  937.             - AIDE has been steadily improved over the last week.
  938.  
  939. 16/1/94            - Tested all example programs under 2.04 and 1.3
  940.               (and also with NoFastMem under 1.3).
  941.  
  942. 19/1/94            - ACE version 2.0 released.
  943.